package cn.qihang.ssm.mapper;

import cn.qihang.ssm.pojo.Permission;
import cn.qihang.ssm.pojo.Role;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * @Author: qihang
 * @Date: 2022/11/3 16:50
 * @Desc:
 */
public interface RoleMapper {

    /**
     * 查询角色
     */
    List<Role> findAll(Integer page, Integer size);

    /**
     * 添加角色
     * @param role
     */
    void save(Role role);


    /**
     * 角色详情
     * @param id
     */
    Role findById(Integer id);


    /**
     * 添加资源权限前-查询哪些资源权限可以添加
     * @param id
     * @return
     */
    List<Permission> findOtherPermissions(Integer id);


    /**
     * 为角色添加资源权限
     * @param roleId
     * @param permissionId
     */
    void addPermissionToRole(@Param("roleId") Integer roleId, @Param("permissionId") Integer permissionId);

    /**
     * 删除角色-从users_role表解除关系
     * @param roleId
     */
    void delete_users_roleById(Integer roleId);


    /**
     * 删除角色-从role_permission表解除关系
     * @param roleId
     */
    void delete_role_permissionById(Integer roleId);


    /**
     * 删除角色-从role表中删除数据
     * @param roleId
     */
    void delete_RoleById(Integer roleId);
}
